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HTTP SERVICE DISCOVERY DEVICE 

FIELD OF THE INVENTION 

[0001] The present invention relates generally to the discovery of various devices 
and services. More particularly, the present invention relates to the discovery of 
devices and services within home networks. 

BACKGROUND OF THE INVENTION 

[0002] There are a number of computer network-related service discovery 
techniques that can be used for a home network, but they are usually not compatible 
with current devices such as existing personal computer browsers and mobile device 
browsers. It is currently believed that the most cost efficient manner for controlling 
other devices at home over a home network, such as a through a wireless local area 
network (WLAN) connection or an Ethernet connection, is to interface to those 
devices using hypertext markup language (HTML) pages. Home consumer devices 
typically have very low cost margins, and therefore there is strong pressure to save 
costs wherever possible. In this situation, the consumer electronics manufacturers 
first implement web-server based control of the devices. 

[0003] In implementing such a system as discussed above, there are currently two 
significant issues. First, when devices have their own web pages, the user needs to 
know the internet protocol (IP) address or the uniform resource locator (URL) of the 
device. Second, there are currently a number of different service discovery protocols, 
including Universal Plug and Play (UPNP), service location protocol (SLP) and 
Juxtapose (JXTA), but each service discovery protocol requires a specific protocol to 
be implemented both in the terminal and in the home devices. 

[0004] Conventionally, general service discovery protocols such as UPNP, SLP, and 
JXTA, service the discovery of web services. Search engines, such as Google, also 
have a similar type of functionality. However, a search engine, when retrieving 
information, will provide the links of unavailable services as well as available 
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services. In other words, even if a device is off at a given moment, the link to the 
device will still be returned by the search engine. 

SUMMARY OF THE INVENTION 

[0005J The present invention provides for a hypertext transfer protocol (HTTP) 
service discovery device (HSDD). This device provides for the discovery of HTTP 
services. The HSDD of the present invention also enables a user to remotely access 
and control devices within a home network. According to the present invention, 
devices within the home network have www-pages, i.e., home computers and 
personal video recorders which are running web servers. These pages are accessible 
from inside the home network or by using a secure remote access-based system 
running on IP Security (IPSEC) or a secure sockets layer (SSL) virtual private 
network (VPN). In order to access a specific device, the user must know the domain 
name system (DNS) name or the IP address of that device. The present invention 
enables the discovery of the devices of any normal web server with any web browser 
by utilising the HSDD. 

[0006] The present invention provides for a number of benefits over conventional 
systems. The present invention provides a more cost efficient way to implement 
home network connectivity to consumer electronics, as it is already supported by 
current implementations. 

[0007] These and other objects, advantages and features of the invention, together 
with the organization and manner of operation thereof, will become apparent from the 
following detailed description when taken in conjunction with the accompanying 
drawings, wherein like elements have like numerals throughout the several drawings 
described below. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0008] Figure 1 is an overview diagram of a system within which the present 
invention may be implemented; 

[0009] Figure 2 is a perspective view of a mobile telephone that can be used in the 
implementation of the present invention; 
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[0010] Figure 3 is a schematic representation of the telephone circuitry of the 
mobile telephone of Figure 2; 

[0011] Figure 4 is a representation of a home network and its interaction with a 
remote device according to one embodiment of the present invention; 
[0012] Figure 5 is a flow chart showing the steps involved in one embodiment of the 
present invention; 

[0013] Figure 6 is a depiction of a sample service guide page according to one 
embodiment of the present invention; and 

[0014] Figure 7 is a depiction of a sample page for one home network device 
according to one embodiment of the present invention. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

[0015] Figure 1 shows a system 10 in which the present invention can be utilized, 
comprising multiple communication devices that can communicate through a 
network. The system 10 may comprise any combination of wired or wireless 
networks including, but not limited to, a mobile telephone network, a wireless Local 
Area Network (LAN), a Bluetooth personal area network, an Ethernet LAN, a token 
ring LAN, a wide area network, the Internet, etc. The system 10 may include both 
wired and wireless communication devices. 

[0016] For exemplification, the system 10 shown in Figure 1 includes a mobile 
telephone network 1 1 and the Internet 28. Connectivity to the Internet 28 may 
include, but is not limited to, long range wireless connections, short range wireless 
connections, and various wired connections including, but not limited to, telephone 
lines, cable lines, power lines, and the like. 

[0017] The exemplary communication devices of the system 10 may include, but 
are not limited to, a mobile telephone 12, a combination PDA and mobile telephone 
14, a PDA 16, an integrated messaging device (IMD) 18, a desktop computer 20, and 
a notebook computer 22. The communication devices may be stationary or mobile as 
when carried by an individual who is moving. The communication devices may also 
be located in a mode of transportation including, but not limited to, an automobile, a 
truck, a taxi, a bus, a boat, an airplane, a bicycle, a motorcycle, etc. Some or all of the 
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communication devices may send and receive calls and messages and communicate 
with service providers through a wireless connection 25 to a base station 24. The base 
station 24 may be connected to a network server 26 that allows communication 
between the mobile telephone network 1 1 and the Internet 28. The system 10 may 
include additional communication devices and communication devices of different 
types. A communication device may communicate using various media including, 
but not limited to, radio, infrared, laser, cable connection, and the like. 
[0018] The communication devices may communicate using various transmission 
technologies including, but not limited to, Code Division Multiple Access (CDMA), 
Global System for Mobile Communications (GSM), Universal Mobile 
Telecommunications System (UMTS), Time Division Multiple Access (TDMA), 
Frequency Division Multiple Access (FDMA), Transmission Control 
Protocol/Internet Protocol (TCP/IP), Short Messaging Service (SMS), Multimedia 
Messaging Service (MMS), e-mail, Instant Messaging Service (IMS), Bluetooth, 
IEEE 802.11, etc. 

[0019] Figures 2 and 3 show one representative mobile telephone 12 within which 
the present invention may be implemented. It should be understood, however, that the 
present invention is not intended to be limited to one particular type of mobile 
telephone 12 or other electronic device. For example, the present invention can be 
incorporated into the N-Gage discussed above. The mobile telephone 12 of Figures 2 
and 3 includes a housing 30, a display 32 in the form of a liquid crystal display, a 
keypad 34, a microphone 36, an ear-piece 38, a battery 40, an infrared port 42, an 
antenna 44, a smart card 46 in the form of a universal integrated circuit card (UICC) 
according to one embodiment of the invention, a card reader 48, radio interface 
circuitry 52, codec circuitry 54, a controller 56 and a memory 58. Individual circuits 
and elements are all of a type well known in the art, for example in the Nokia range of 
mobile telephones. 

[0020] Figure 4 shows a representation of a simplified home network 100. The 
present invention provides for a HTTP service discovery device, or HSDD, which 
provides discovery of HTTP services. Typically, a user has a number of devices 
within the home network 100, with the various devices including www-pages. The 
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devices may include, for example, a notebook computer 22, a personal video recorder 
102, and other devices which run web servers. Virtually any other type of device that 
is compatible with the home network 100 can also be included. The home network 
100 also includes a home control center 104, also sometimes referred to as a control 
personal computer, and an access point 1 06 through which a user can communicate 
with the various devices through a browser 108 on a remote device 110. In Figure 4, 
a portion of a mobile telephone 12 is shown as the remote device 110, although a 
wide variety of devices can be used for such communication. 

[0021] The respective www pages are accessible from inside the home network 100 
through a WLAN or Ethernet segment, or by using secure remote access based 
systems such as IPSEC or SSL VPN. In order to access a specific device, the user 
must know the DNS name or IP address of that device. The present invention enables 
the discovery of the devices of any normal web server with any normal web browser 
by utilizing the HSDD, which is depicted at 1 12 in Figure 4. 
[0022] In one embodiment of the invention, the implementation of the present 
invention is carried out according to the flow chart of Figure 5. In this particular 
implementation, the HSDD 1 12 is located in the access point 106 for the home 
network 100. It is also possible for the HSDD 1 12 to be located in other devices or to 
be a stand-along device. It should also be noted that the HSDD may be incorporated 
into a device with circuitry such as that depicted in Figure 3. The access point 106 
serves as the gateway between the external network, such as the Internet 28, and the 
home network 100. At step 500, the HSDD 1 12 provides private IP addresses to the 
various home network devices with dynamic host configuration protocol (DHCP) and 
provides Network Address Translation (NAT) services between the external network 
and the home network 100. When the HSDD 1 12 is located in the access point 106, it 
has access to the NAT addresses of all the client devices within the home network 
100. Therefore, the HSDD 1 12 has the knowledge of all devices and their IP 
addressed within the home network 1 00. 

[0023] At step 510, the HSDD 1 12 makes a series of HTTP requests to the IP 
addresses of the devices in the home network 100. At step 520, the HSDD 112 parses 
the title text or similar information from the main HTML page of each device (i.e. the 
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index.HTML page). At step 530, the HSDD 1 12 records this information, as well as 
the IP address or DNS name of the device in the form of a URL. 
[0024] When all of the devices in the home network 100 have been polled for this 
information, the HSDD 1 12 creates a web page at step 540, referred to herein as a 
service guide page, containing all of the information that was gathered. The service 
guide page is stored locally in the HSDD 112. At step 550, a user accesses the service 
guide page through his or her remote device 110 with a predetermined URL name 
such as "request.myhome.net." The service guide page includes a list of names for 
the devices within the home network 1 00. When a user selects a name from the list, 
as represented at step 560, the remote device 110 will display a main web page for 
that specific device. At step 565, the user can then manipulate the main web page 
(e.g., by actuating individual links) in order to remotely control the respective device 
within the home network 100. This can be accomplished, for example, by embedding 
JavaScript in the main web page. 

[0025] In one embodiment of the invention, the HSDD 112 may also utilize the 
knowledge of the media access control (MAC) addresses in the Local Area Network 
segment, as this information is available within the particular gateway device. This 
feature allows the HSDD 1 12 to build a clear picture of which devices were available 
in the network at any given time, without the need for constant polling. For example, 
when a home network device is turned off, represented at step 570, this event is 
noticed at the gateway device at the network level. The HSDD 112 therefore can be 
informed of this event by the networking software at step 580, and this information 
can be used to recreate and/or otherwise modify the service guide page, represented at 
step 590. A similar situation can occur whenever a new device enters the home 
network 1 00, or when other activities occur. 

[0026] The following is one depiction of the security and implementation of one 
particular embodiment of the present invention. In a home network 100 of the type 
depicted in Figure 4, the access point 106 has a public IP address of 10.20.30.40. The 
access point 106 has a NAT and DHCP server that gives an address of 192. 168.1. xxx. 
The IP addresses given to the various home network devices are 198.168.1.1 for the 
personal video recorder 102; 192.168.1.2 for the notebook computer 22, and 
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192.168.1 .3 for the home control center 104. Any connection that comes to the 
10.20.30.40 IP address must be authenticated with transport layer security (TLS). If 
the connection is not authenticated, then the access point 106 discards the respective 
packets of information. The access point 1 06 has port forwarding, so that 
10.20.30.40:1 is forwarded to 192.168.1.1:80, 10.20.30.40:2 is forwarded to 
192.168.1.2:80, and 10.20.30.40:3 is forwarded to 192.168.1.3:80. When the service 
guide page is displayed, the following links are shown, as depicted in Figure 6: 
<a href=http://l 0.20.30.40: l>PVR</a> 
<a hrefHittp://10.20.30.40:2>PC</a> 
<a href^http://10.20.30.40:3>Control PC</a> 

[0027] When a user selects <a href^http://l 0.20.30.40: l>PVR</a>, a new page 
appears on the remote device 1 10, as depicted in Figure 7. 

[0028] Most home networking technologies support events where devices report 
their state to any other networked device which has registered an interest. An HSDD 
of the present invention can support this feature by polling the networked devices and 
updating the service guide as necessary. 

[0029] The invention is described in the general context of method steps, which 
may be implemented in one embodiment by a program product including computer- 
executable instructions, such as program code, executed by computers in networked 
environments. Generally, program modules include routines, programs, objects, 
components, data structures, etc. that perform particular tasks or implement particular 
abstract data types. Computer-executable instructions, associated data structures, and 
program modules represent examples of program code for executing steps of the 
methods disclosed herein. The particular sequence of such executable instructions or 
associated data structures represents examples of corresponding acts for implementing 
the functions described in such steps. 

[0030] Software and web implementations of the present invention could be 
accomplished with standard programming techniques with rule based logic and other 
logic to accomplish the various database searching steps, correlation steps, 
comparison steps and decision steps. It should also be noted that the words 
"component" and "module" as used herein and in the claims is intended to encompass 
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implementations using one or more lines of software code, and/or hardware 
implementations, and/or equipment for receiving manual inputs. 
[0031] The foregoing description of embodiments of the present invention have 
been presented for purposes of illustration and description. It is not intended to be 
exhaustive or to limit the present invention to the precise form disclosed, and 
modifications and variations are possible in light of the above teachings or may be 
acquired from practice of the present invention. The embodiments were chosen and 
described in order to explain the principles of the present invention and its practical 
application to enable one skilled in the art to utilize the present invention in various 
embodiments and with various modifications as are suited to the particular use 
contemplated. 
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